package com.example.leetcode.c901_end.c941;
/**
 * 给定一个整数数组 A，如果它是有效的山脉数组就返回 true，否则返回 false。
 *
 * 让我们回顾一下，如果 A 满足下述条件，那么它是一个山脉数组：
 *
 * A.length >= 3
 * 在 0 < i < A.length - 1 条件下，存在 i 使得：
 * A[0] < A[1] < ... A[i-1] < A[i]
 * A[i] > A[i+1] > ... > A[A.length - 1]
 *  
 *
 *
 *
 *  
 *
 * 示例 1：
 *
 * 输入：[2,1]
 * 输出：false
 * 示例 2：
 *
 * 输入：[3,5,5]
 * 输出：false
 * 示例 3：
 *
 * 输入：[0,3,2,1]
 * 输出：true
 *  
 *
 * 提示：
 *
 * 0 <= A.length <= 10000
 * 0 <= A[i] <= 10000 
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/valid-mountain-array
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */

/**
 * 有效的山脉数组
 * @author zhanpengguo
 * @date 2020-11-03 8:09
 */
public class Solution {

    public boolean validMountainArray(int[] A) {
        if (A.length < 3) {
            return false;
        }
        boolean ans = false;
        for (int i = 1; i < A.length - 1; i++) {
            if (A[i] == A[i - 1] || A[i] == A[i + 1]) {
                return false;
            }
            if (A[i] < A[i - 1] && A[i] < A[i + 1]) {
                return false;
            }
            if (A[i] > A[i - 1] && A[i] > A[i + 1]) {
                ans = true;
            }
        }
        return ans;
    }

    public boolean validMountainArray1(int[] A) {
        if (A.length < 3) {
            return false;
        }
        int left = 0;
        int right = A.length - 1;
        while (left < A.length - 2) {
            if (A[left + 1] > A[left]) {
                left++;
            } else {
                break;
            }
        }
        while (right > 1) {
            if (A[right] < A[right - 1]) {
                right--;
            } else {
                break;
            }
        }
        return left == right;
    }

    public static void main(String[] args) {
        Solution solution = new Solution();
        int[] A = {0};
        boolean b = solution.validMountainArray1(A);
        System.out.println(b);
    }
}
